<!doctype html>
<html>
    <head>
        <title>HT 虚线流动手册</title>
        <meta charset="UTF-8">    
        <meta name="viewport" content="user-scalable=yes, width=1024">
        <style type="text/css"> 
            h1, h2, h3, h4, h5, h6, p, blockquote {
                margin: 0;
                padding: 0;
            }
            body {
                font-family: "Helvetica Neue", Helvetica, "Hiragino Sans GB", Arial, sans-serif;
                font-size: 13px;
                line-height: 18px;
                color: #737373;
                background-color: white; 
                margin: 10px 13px 10px 13px;
            }
            table {
                margin: 10px 0 15px 0;
                border-collapse: collapse;
            }
            td,th {	
                border: 1px solid #ddd;
                padding: 3px 10px;
            }
            th {
                padding: 5px 10px;	
            }
            a {
                color: #0069d6;
            }
            a:hover {
                color: #0050a3;
                text-decoration: none;
            }
            a img {
                border: none;
            }
            p {
                margin-bottom: 9px;
            }
            h1, h2, h3, h4, h5, h6 {
                color: #404040;
                line-height: 36px;
            }
            h1 {
                margin-bottom: 18px;
                font-size: 30px;
            }
            h2 {
                font-size: 24px;
            }
            h3 {
                font-size: 18px;
            }
            h4 {
                font-size: 16px;
            }
            h5 {
                font-size: 14px;
            }
            h6 {
                font-size: 13px;
            }
            hr {
                margin: 0 0 19px;
                border: 0;
                border-bottom: 1px solid #ccc;
            }
            blockquote {
                padding: 13px 13px 21px 15px;
                margin-bottom: 18px;
                font-family:georgia,serif;
                font-style: italic;
            }
            blockquote:before {
                content:"\201C";
                font-size:40px;
                margin-left:-10px;
                font-family:georgia,serif;
                color:#eee;
            }
            blockquote p {
                font-size: 14px;
                font-weight: 300;
                line-height: 18px;
                margin-bottom: 0;
                font-style: italic;
            }
            code, pre {
                font-family: Monaco, Andale Mono, Courier New, monospace;
            }
            code {
                background-color: #fee9cc;
                color: rgba(0, 0, 0, 0.75);
                padding: 1px 3px;
                font-size: 12px;
                border-radius: 3px;
            }
            pre {
                display: block;
                padding: 14px;
                margin: 0 0 18px;
                line-height: 16px;
                font-size: 11px;
                border: 1px solid #d9d9d9;
                white-space: pre-wrap;
                word-wrap: break-word;
            }
            pre code {
                background-color: #fff;
                color:#737373;
                font-size: 11px;
                padding: 0;
            }
            sup {
                font-size: 0.83em;
                vertical-align: super;
                line-height: 0;
            }
            * {
                -webkit-print-color-adjust: exact;
            }
            @media screen and (min-width: 914px) {
                body {
                    width: 854px;
                    margin:10px auto;
                }
            }
            @media print {
                body,code,pre code,h1,h2,h3,h4,h5,h6 {
                    color: black;
                }
                table, pre {
                    page-break-inside: avoid;
                }
            }                        
            iframe{
                width: 100%;
                border: 1px solid #34495E;
                margin: 0;                
            }            
            .logo{
                vertical-align: middle;
            }

        </style>        
        <script>
            function init() {
                var logoSrc = '',
                    logos = document.querySelectorAll('.logo'),
                    i = 0;
                for (; i < logos.length; i++) {
                    logos[i].src = logoSrc;
                }
                
                var iframes = document.querySelectorAll('iframe'),
                    func = function(){};
                for (i=0; i < iframes.length; i++) {
                    var iframe = iframes[i];
                    
                    // a small hack to make it work on android
                    iframe.ontouchstart = func;
                    
                    var div = document.createElement('div');
                    div.innerHTML = '<a href="' + iframe.src + '" target="_blank">独立运行→</a>';
                    iframe.parentNode.insertBefore(div, iframe);
                }   
            }
        </script>    
    </head>
    <body onload="init();">
        <a href="http://www.hightopo.com"><img class="logo"></a>HT 虚线流动手册
        <hr style="margin: 1px 0 20px 0">
<p>索引</p>

<ul><li><a href="#ref_description">概述</a></li><li><a href="#ref_demo1">示例一：综合示例</a></li><li><a href="#ref_demo2">示例二：与EdgeType插件集成</a></li></ul>

<hr/>

<div id="ref_description"></div>

<h3>概述</h3>

<p><code>HT</code>核心产品包中的<code>ht.Edge</code>和<code>ht.Shape</code>已经支持斑马线效果，如果需要流动，您可以使用<code>setTimeout</code>函数改变图元<code>*.dash.offset</code>样式，
或者使用<code>Animation</code>插件，但是这两种方式是基于事件机制的刷新，可能会影响到性能。</p>

<p>此插件内部启动一个定时器，定时遍历<code>DataModel</code>中的数据并重绘，略过了事件派发的过程，如果您的应用对性能非常敏感，请使用此插件</p>

<p>和流动插件类似，此插件没有引入新的类，只是在<code>ht.Shape</code>、<code>ht.Edge</code>和<code>ht.graph.GraphView</code>上扩展了一些方法或样式，因此非常易于使用。要使用此插件，只需要引入<code>ht-dashflow.js</code>文件：</p>

<pre><code>&lt;script src=&quot;ht.js&quot;&gt;&lt;/script&gt; &lt;!--先引入ht.js--&gt;
&lt;script src=&quot;ht-dashflow.js&quot;&gt;&lt;/script&gt;</code></pre>

<p>注意：使用此插件需要安装最新版的<code>Chrome</code>、<code>Firefox</code>或<code>IE11</code>浏览器(不支持<code>IE10</code>及<code>IE9</code>)</p>

<p>此插件在<code>ht.Shape</code>和<code>ht.Edge</code>类上扩展了一些样式控制流动效果，您可以通过<code>ht.Shape#setStyle</code>和<code>ht.Edge#setStyle</code>操作这些样式，
说明如下：</p>

<ul><li><code>edge.dash.flow</code> 值为<code>true</code>或<code>false</code>，是否启用<code>ht.Edge</code>的虚线流动，默认值为<code>false</code></li><li><code>shape.dash.flow</code> 值为<code>true</code>或<code>false</code>，是否启用<code>ht.Shape</code>的虚线流动，默认值为<code>false</code></li><li><code>edge.dash.flow.step</code> <code>ht.Edge</code>虚线流动的步进，默认值为<code>3</code></li><li><code>shape.dash.flow.step</code> <code>ht.Shape</code>虚线流动的步进，默认值为<code>3</code></li><li><code>edge.dash.flow.reverse</code> 值为<code>true</code>或<code>flase</code>，控制<code>ht.Edge</code>的反向流动，默认值为<code>false</code></li><li><code>shape.dash.flow.reverse</code> 值为<code>true</code>或<code>flase</code>，控制<code>ht.Shape</code>的反向流动，默认值为<code>false</code></li></ul>

<p><code>ht.graph.GraphView</code>上扩展的<code>API</code>如下：</p>

<ul><li><code>enableDashFlow(interval)</code> 启动虚线流动，默认为<code>false</code>，<code>interval</code>表示流动的时间间隔</li><li><code>disableDashFlow()</code> 停止虚线流动</li><li><code>dashFlowInterval</code> 通过<code>setDashFlowInterval(interval)</code>和<code>getDashFlowInterval()</code>操作，控制虚线流动的时间间隔</li></ul>

<p>从上面的说明中可以看出，拓扑上的所有<code>Data</code>的虚线流动的时间间隔是一样的，如果需要营造不同的<code>Data</code>流动速度不同的效果，可以修改相关<code>Data</code>的<code>*.dash.flow.step</code>样式。</p>

<div id="ref_demo1"></div>

<h3>示例一：综合示例</h3>

<p>此插件可以和流动插件及扩展编辑插件一同使用,您可以操作下面的例子验证此插件：</p>

<p><iframe src="examples/example_demo1.html" style="height:300px"></iframe></p>

<div id="ref_demo2"></div>

<h3>示例二：与EdgeType插件集成</h3>

<p>实际上，与<code>EdgeType</code>插件集成时您不需要做任何额外的处理，按原有的方式使用这两个插件各自的<code>API</code>即可：</p>

<p><iframe src="examples/example_demo2.html" style="height:500px"></iframe></p>

<p>这个例子里使用了全局的默认样式配置：</p>

<pre><code>&lt;script type=&quot;text/javascript&quot;&gt;
    htconfig = {
        Style: {
            &#39;edge.width&#39;: 2,
            &#39;edge.color&#39;: &#39;red&#39;,
            &#39;edge.dash&#39;: true,
            &#39;shape.dash&#39;: true,
            &#39;edge.dash.color&#39;: &quot;yellow&quot;,
            &#39;shape.dash.color&#39;: &quot;yellow&quot;,
            &#39;edge.dash.flow&#39;: true,
            &#39;shape.dash.flow&#39;: true
        }
    };
&lt;/script&gt;</code></pre>

<p>这种语法结构的详细信息可以参考<a href="../../core/theme/ht-theme-guide.html">Theme</a>文档</p>    <hr id="contact" style="margin: 20px 0 1px 0">
    <a href="http://www.hightopo.com"><img class="logo"></a>欢迎交流 <a href="mailto:service@hightopo.com">service@hightopo.com</a>
</body>
</html>
